草庐IT

php - 运行多个 PHP MySQL 查询

全部标签

ruby-on-rails - 多个数据库的测试和 database_cleaner

我们有一个邮箱模型,它使用另一个邮件应用程序也连接到的辅助数据库。这称为使用establish_connection:mail_database现在,我想我可以尝试将它包装在if语句中,以便它为测试环境使用不同的连接,但我想知道如何保持这个数据库的清洁,最好使用我们已经将其用于“常规”数据库的database_cleaner。我希望有人能将我推向正确的方向。 最佳答案 我有一个使用rspec(2.12.0)和使用database_cleaner(0.9.1f4b44bb)测试的rails3.2.10应用程序,它有两个用于mysql的

ruby-on-rails - Rails,如何避免 "N + 1"查询关联中的总数(计数、大小、counter_cache)?

我有这些模型:classChildren我现在需要的是在“电影院”的页面中,我想为那个电影院的电影打印children的总和(数量,大小?),所以我这样写:在cinemas_controller.rb中:@childrens=@cinema.childrens.uniq在cinemas/show.html.erb:但显然我有bulletgem提醒我Counter_cache并且我不知道把这个counter_cache放在哪里因为电影的不同id。而且在没有counter_cache的情况下,我所拥有的也不是我想要的,因为我想要计算该电影院中有多少child从该电影院许多天的门票中拿走了他

ruby - 从 map 返回多个值

有什么办法可以做到:a=b.map{|e|#returnmultipleelementstobeaddedtoa}不是为要添加到a的每个迭代返回单个对象,而是可以返回多个对象。我目前正在通过以下方式实现这一目标:a=[]b.map{|e|a.concat([x,y,z])}有没有办法在一行中完成此操作而无需预先声明a=[]? 最佳答案 使用Enumerable#flat_mapb=[0,3,6]a=b.flat_map{|x|[x,x+1,x+2]}a#=>[0,1,2,3,4,5,6,7,8]

ruby-on-rails - Rails 3.0.7 -> 如何让测试运行得更快?

我正在运行mysql、database_cleaner、Rspec等。到目前为止我有大约518个测试,它们需要88秒才能运行。这对我来说是NotAcceptable,因为我的应用程序开发才刚刚开始。因此,在进一步深入之前,我想尝试找到减少运行这些测试所需时间的方法-希望不必实际更改测试。在大多数情况下,我尝试使用stub。但是,当我测试模型和查询时,我会使用数据库。我认为database_cleaner正在减慢它们的速度,但我不知道如何在没有它的情况下测试查询和其他内容。使用带有“:memory:”选项的sqlite3似乎只减少了大约10秒(有点令人失望的结果......)我该怎么做才

ruby - 从命令行运行 Ruby 库

在对Python非常满意几年后,我刚刚学习了Ruby的基础知识(我仍在使用Python做某些事情),但我想知道是否有成语或hack来解决这个特殊问题问题。我有一个Ruby脚本,我希望能够用它执行requirescript_name,但我也希望能够运行rubyscript_name.rb从终端并将其作为命令行脚本运行。在Python中,这将通过在脚本底部具有以下结构来完成:if__name__=='__main__':#dosomethinghere但是,我似乎找不到Ruby中的等效项。有没有办法检测当前脚本是否正在从命令行运行?也许是一些Kernel::方法之类的?理想情况下,我想要的

ruby-on-rails - 运行 autoconf 时 rvm install 1.9.2 失败?

当我运行时rvminstall1.9.2我在尝试运行autoconf时遇到错误。这是堆栈跟踪:kenmare:ruby-1.9.2-p0lee$rvminstall1.9.2-p0/Users/lee/.rvm/rubies/ruby-1.9.2-p0,thismaytakeawhiledependingonyourcpu(s)...ruby-1.9.2-p0-#fetchingruby-1.9.2-p0-#extractedto/Users/lee/.rvm/src/ruby-1.9.2-p0(alreadyextracted)RunningautoconfErrorrunning'

ruby-on-rails - gem install mysql2 v '0.3.11' 无法在 Yosemite 上运行

在ruby​​版本1.9.3(rvm)上执行mysql2版本0.3.11的捆绑安装或直接gem安装时,我收到以下错误。但是当我安装最新版本0.3.16时它可以工作。我还包含了我的gcc版本以供引用。Gem::Ext::BuildError:ERROR:Failedtobuildgemnativeextension./Users/ginocarlocortez/.rvm/rubies/ruby-1.9.3-p547/bin/rubyextconf.rbcheckingforrb_thread_blocking_region()...yescheckingforrb_wait_for_si

ruby 为给定值获取多个哈希键的有效方法

从给定值中获取所有哈希键的最有效方法是什么。my_hash={"a"=>"aa","b"=>"bb","c"=>"bb"}我想将散列“bb”作为输入值并将它们的所有键(b,c)作为数组返回只返回一个键:my_hash.index("bb")#returnsonlyb这有效但似乎效率低下:my_hash.select{|k,v|v=='bb'}.map{|i|i[0]}#returnsbandc我已经阅读了所有文档。我觉得我缺少了一些明显的东西。谢谢!更新:我最终切换了哈希创建的键和值,并使用数组作为值。这是一个更有效的解决方案。如果需要,请参阅下文了解进行值(value)查找的最佳方法

ruby-on-rails - 数组上的 rails where() sql 查询

我会尽可能详细地解释这一点。我对用户帖子有疑问:@selected_posts=Posts.where(:category=>"棒球")我想写下面的语句。这是伪术语:User.where(用户在@selected_posts中有帖子)请记住,我设置了多对多关系,因此post.user可用。有什么想法吗?/编辑@posts_matches=User.includes(@selected_posts).map{|user|[user.company_name,user.posts.count,user.username]}.sort基本上,我需要上面的工作,以便它使用在selected_p

ruby-on-rails - 在一台专用服务器上运行两个不同的 Rails 应用程序

我有一台配置如下的专用服务器i3-DualCore-3.06GhzH/T16GBRAM500GBSATA2现在我想在一台专用服务器上执行两个不同的Rails应用程序。两个应用程序都不同,但它们使用的是公共(public)数据库。这有可能吗?如果是——我该怎么做?使用Apache的PhusionPassenger是一个好方法吗?如果是-如何使用一台PhusionPassenger服务器配置两个应用程序? 最佳答案 我将描述如何使用Apache、PhusionPassenger和某些版本的Ruby在一台Linux服务器上运行多个Rail